文件下载(V5.1.21+

5.1.21+版本开始,支持文件下载功能,可以更简单的读取文件进行下载操作,支持直接下载输出内容。

你可以在控制器的操作方法中添加如下代码:

  1. public function download()
  2. {
  3. $download = new \think\response\Download('image.jpg');
  4. return $download->name('my.jpg');
  5. // 或者使用助手函数完成相同的功能
  6. // download是系统封装的一个助手函数
  7. return download('image.jpg', 'my.jpg');
  8. }

访问download操作就会下载命名为my.jpg的图像文件。

下载文件的路径是服务器路径而不是URL路径,如果要下载的文件不存在,系统会抛出异常。

下载文件名可以省略后缀,会自动判断(后面的代码都以助手函数为例)

  1. public function download()
  2. {
  3. // 和上面的下载文件名是一样的效果
  4. return download('image.jpg', 'my');
  5. }

如果需要设置文件下载的有效期,可以使用

  1. public function download()
  2. {
  3. // 设置300秒有效期
  4. return download('image.jpg', 'my')->expire(300);
  5. }

除了expire方法外,还支持下面的方法:

方法 描述
name 命名下载文件
expire 下载有效期
isContent 是否为内容下载
mimeType 设置文件的mimeType类型

助手函数提供了内容下载的参数,如果需要直接下载内容,可以在第三个参数传入true

  1. public function download()
  2. {
  3. $data = '这是一个测试文件';
  4. return download($data, 'test.txt', true);
  5. }